package 系统复习.数组;

/**
 * 给你一个非负整数 x ，计算并返回 x 的 算术平方根 。
 * 由于返回类型是整数，结果只保留 整数部分 ，小数部分将被 舍去 。
 * 注意：不允许使用任何内置指数函数和算符，例如 pow(x, 0.5) 或者 x ** 0.5 。
 *
 * 最好就是使用 二分法
 */


public class L69 {

    public static int mySqrt(int x) {
        if (x <= 1) return x;
        long temp = x / 2;
        while ( temp > 0) {
            if (temp * temp > x) {
                temp = temp / 2;
            } else {
                break;
            }
        }
        do {
            temp++;
        } while (temp * temp <= x);
        return (int)--temp;
    }


    public static void main(String[] args) {
        System.out.println(mySqrt(2147395599));
    }
}
